<html lang="en-US">

<head>
    
<title>快速了解 2020 Gopher Meetup 深圳站 - 花落雨忧</title>

<meta property="og:title" content="快速了解 2020 Gopher Meetup 深圳站 - 花落雨忧">



    



    
    <meta property="description" content="昨天（20201017）很有幸的参加了 GoCN 的 2020 Gopher Meetup 深圳站，在台下听各位大佬分享各自的知识和案例。恰好也是我第一次参加这类 Meetup。因此希望也能够让没来的小伙伴对本次分享内容有一定的了解。
按过往对其观察的惯例，一般在下周后官方就会陆续释出 Meetup PPT 和推文，在此引个主线。
本次 Meetup 主要的方向是云原生，包含四位讲师分享，分享的主 &amp;hellip;">
    <meta property="og:description" content="昨天（20201017）很有幸的参加了 GoCN 的 2020 Gopher Meetup 深圳站，在台下听各位大佬分享各自的知识和案例。恰好也是我第一次参加这类 Meetup。因此希望也能够让没来的小伙伴对本次分享内容有一定的了解。
按过往对其观察的惯例，一般在下周后官方就会陆续释出 Meetup PPT 和推文，在此引个主线。
本次 Meetup 主要的方向是云原生，包含四位讲师分享，分享的主 &amp;hellip;">
    






<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1">

<link rel="shortcut icon" href="https://www.lican.asia/logo/logo.png" type="image/x-icon" />



<link rel="stylesheet" href="/css/style.min.css" />

<link rel="stylesheet" href="/css/reset.min.css" />




<script src="https://www.lican.asia/js/highlight.min.js"></script>

<script>
hljs.configure({ ignoreUnescapedHTML: true })
hljs.highlightAll();
</script>


<script src="https://www.lican.asia/js/jquery.min.js"></script>




<link href="https://www.lican.asia/css/hugo-code.min.css" rel="stylesheet" />



    <style>
        .post-content img {
            max-width: 400px;
        }
    </style>
</head>

<body id="period" class="home blog">
    <a class="skip-content" href="#main">Press "Enter" to skip to content</a>
    <div id="overflow-container" class="overflow-container">
        <header class="site-header" id="site-header" role="banner">
    <div class="max-width">
        <div id="title-container" class="title-container">
            <div id="site-title" class="site-title"><a href="/">花落雨忧</a></div>
            <p class="tagline">思所及 力所行 方为真.</p>
        </div>
        
        <div id="menu-primary-container" class="menu-primary-container">
            <div class="icon-container">
            </div>
            <div id="menu-primary" class="menu-container menu-primary" role="navigation">
                <nav class="menu">
                    <ul id="menu-primary-items" class="menu-primary-items">
                        
                        
                        <li id="menu-item-0"
                            class="menu-item menu-item-type-custom menu-item-object-custom ">
                            <a href="/posts" aria-current="page" tabindex="0">首页</a></li>
                        
                        <li id="menu-item-1"
                            class="menu-item menu-item-type-custom menu-item-object-custom ">
                            <a href="/tech/" aria-current="page" tabindex="1">技术文档</a></li>
                        
                        <li id="menu-item-2"
                            class="menu-item menu-item-type-custom menu-item-object-custom ">
                            <a href="/article/" aria-current="page" tabindex="2">文章</a></li>
                        
                        <li id="menu-item-3"
                            class="menu-item menu-item-type-custom menu-item-object-custom ">
                            <a href="/project/" aria-current="page" tabindex="3">项目</a></li>
                        
                        <li id="menu-item-4"
                            class="menu-item menu-item-type-custom menu-item-object-custom ">
                            <a href="/about/" aria-current="page" tabindex="4">关于</a></li>
                        
                    </ul>
                </nav>
            </div>
        </div>
    </div>
</header>

        <div id="primary-container" class="primary-container">
            <div class="max-width">
                <section id="main" class="main" role="main">
                    <div id="loop-container" class="loop-container">
                        <div
                            class="post type-post status-publish format-standard hentry entry">
                            <article>
                                <div class="post-container">
                                    <div class="post-header">
                                        <h2 class="post-title">
                                            <a href="/posts/posts/go-meetup1017/">快速了解 2020 Gopher Meetup 深圳站</a>
                                        </h2>
                                        
                                        <div class="post-byline">Published on
                                            <a class="date" href="javascript:;">2020/10/18</a>
                                            
                                            
                                            
                                            
                                            
                                        
                                    </div>
                                    <div class="post-content">
                                        <p>昨天（20201017）很有幸的参加了 GoCN 的 2020 Gopher Meetup 深圳站，在台下听各位大佬分享各自的知识和案例。恰好也是我第一次参加这类 Meetup。因此希望也能够让没来的小伙伴对本次分享内容有一定的了解。</p>
<p>按过往对其观察的惯例，一般在下周后官方就会陆续释出 Meetup PPT 和推文，在此引个主线。</p>
<p><img src="https://image.eddycjy.com/08910eccd6b1b0c16c0f60571cd7745a.jpeg" alt="会场外的展板，图来自 GoCN"></p>
<p>本次 Meetup 主要的方向是云原生，包含四位讲师分享，分享的主题如下：</p>
<ol>
<li>华为云的 go 语言云原生实践。</li>
<li>go 云上微服务模式解构。</li>
<li>服务网格在边缘计算领域的实践与探索。</li>
<li>腾讯大规模 etcd 集群治理与优化实践。</li>
</ol>
<h2 id="华为云的-go-语言云原生实践">华为云的 go 语言云原生实践</h2>
<p>讲述华为云在早起使用 Go 语言时，当时 Go 语言的整体生态圈还比较薄弱，因此很多第三方基础/工具库并不全：</p>
<p><img src="https://image.eddycjy.com/4adaf1b0b465a3197a9ba9d714dda51d.jpeg" alt=""></p>
<p>围绕此整体做一系列的东西，主要从统一框架开始做，提供各种插件，组件，基本涵盖了常用的所有组件。其所带来的的价值/效益：能够直接提高研发效能，让其他业务能够简单使用，不需要太重复造轮子：</p>
<p><img src="https://image.eddycjy.com/8c0afff2cb0bb6d2901d1e4d7f8296f2.jpeg" alt=""></p>
<p>再往后就介绍了其使用了 Mesh 去做整块的流量标识，金丝雀等流量控制方案。同时还支持了市面上常见的框架和协议。是一个比较完整很常见的整体解决方案，有真实的参考意义。</p>
<p>若在企业内部有建设过这类基础应用可能会感触比较深，且各家多多少少都有类似的东西，需要必需品。社区的小伙伴可以多看看，结合自己的实际情况进行选型或融合。</p>
<p>同时该类基础规范，最难的可能还是如何在企业内部达到大一统，做推广，拿规范，遵守则。</p>
<h2 id="go-云上微服务模式解构">go 云上微服务模式解构</h2>
<p>详细介绍了云原生的定义，主体讲解了 k8s 的基本网络模型，核心在于传统微服务模式和云原生模式下的各类优缺点和对比。</p>
<h3 id="edge-proxy">Edge Proxy</h3>
<p><img src="https://image.eddycjy.com/0275954e8196ac7c687a1c58e1b4be23.jpeg" alt=""></p>
<h3 id="servicemesh">ServiceMesh</h3>
<p><img src="https://image.eddycjy.com/794182e59306fec93128765f1854a353.jpeg" alt=""></p>
<p>需要听讲者有一定的基础，整体语速相当快，口述内容也比较多，因此这块没有过多详细记述。</p>
<p>演讲内容主体对应云原生下的几种部署模式，线上的话在网上查阅资料学习即可，可能会更高效些。</p>
<p>印象比较深的是，讲师表述目前也没用 ServiceMesh，四年前也预演过，但问题不少，近期打算重新启动。这块我司也多次尝试，多多少少都有些问题，期待 Istio 更稳定成熟的一天。</p>
<h2 id="服务网格在边缘计算领域的实践与探索">服务网格在边缘计算领域的实践与探索</h2>
<p>主体介绍边缘计算相关的 KubeEdge、IEF 等技术体系：</p>
<p><img src="https://image.eddycjy.com/ddab54efbf97b478c4ea06c8a602dcef.jpeg" alt=""></p>
<p>这块不是我的技术领域内，隔壁的小哥也没听懂，稍微有些乱，因此不过多的介绍。</p>
<p>但发现讲师刚毕业一年多，年轻有为，潜力无限。</p>
<h2 id="腾讯大规模-etcd-集群治理与优化实践">腾讯大规模 etcd 集群治理与优化实践</h2>
<p>腾讯云近期推出了 etcd 的云服务，先前关注了一番。恰好这次的分享者就是相关人士。</p>
<p>分享内容主要分为两个部分：</p>
<ol>
<li>
<p>etcd 本身的基本知识</p>
</li>
<li>
<p>etcd 云服务的介绍</p>
</li>
</ol>
<h3 id="etcd-知识">etcd 知识</h3>
<p>第一部分是 etcd 的基本知识，以及抽出 kubectl 查询作为案例进行逻辑分析：</p>
<p><img src="https://image.eddycjy.com/515c7ea827f0d19b0cedab48897ddc62.jpeg" alt=""></p>
<p>再更一步介绍了 etcd 读请求分析，软件分层，以及一些内部逻辑，流转模型等：</p>
<p><img src="https://image.eddycjy.com/fe56478c26fcbcf2b7441e27156f125b.jpeg" alt=""></p>
<p>若有兴趣的小伙伴可以结合 PPT 再去追一遍源码，会比较的有意思。</p>
<p>因为其讲述的具体的操作模式涉及了 etcd 里的基本理念，大部分情形下都会展开讨论。</p>
<h3 id="etcd-云服务">etcd 云服务</h3>
<p>第二部分是讲解腾讯云自身在做 etcd 云服务时，遇到的一些 etcd 自身的 BUG，利用了 Chaos 来制造混沌，以此来更好的发现问题。并在后半部分讲述了 etcd 云服务的大体设计和内部模块结构：</p>
<p><img src="https://image.eddycjy.com/f864e44559ea61f3a666ce676bf2d5f3.jpeg" alt=""></p>
<p>后半部分感觉比较贴近产品介绍，因为每个模块都能单独拿出来再做一次分享，有限的时间能也很难讲深。</p>
<p>印象最深的还是 “为什么 kubernetes 会选型 etcd？”，讲师给出的答案是：Watch 机制、高可用、商业原因。</p>
<p>各位可以细品一下。</p>
<h2 id="总结">总结</h2>
<p>整体来讲，个人感觉本次 Meetup 以技术的半解决方案和理念介绍居多。</p>
<p>一个技术的实际应用，普遍分三部分来看：</p>
<ol>
<li>
<p>在价值上：为什么要这么做，做了对公司，对团队，对个人的利弊，外部/内部价值是什么。</p>
</li>
<li>
<p>在技术上：技术攻坚，这个大家接触的多。</p>
</li>
<li>
<p>在推广上：，如何规范，推广，是行政命令，还是深抓用户痛点，怎么落的地，是非常重要的。</p>
</li>
</ol>
<p>技术类 Meetup 一般以技术角度居多，因此在与会前，建议提前了解一些基本知识才能在会议上更好的听懂、发散以及思考，否则很难碰撞出火花出来。</p>
<p>但问题又来了，如果已经有了基本知识，肯定会做知识拓展，因此直接网上查阅资料和与业界朋友沟通能达到更佳的目的，更高的时间效率比。因此这是一个矛盾和定位。</p>
<p>其实每一次 Meetup 的背后，组织方和分享讲师其实都会付出大量的精力，都不容易。</p>
<p>抛出一个问题，<strong>如果你是讲师，你怎么在 40-60 分钟内把一份 PPT 讲好？把知识/价值传达到位？</strong></p>


                                        
                                        
                                        
                                        
                                    </div>

                                    
                                    
                                    

                                    
                                    <div class="post-meta">
                                        
                                        
                                        <div class="post-tags">
                                            <ul>
                                            
                                            <li>
                                                <a href="/tags/meetup" title="View all posts tagged match">meetup</a>
                                            </li>
                                            
                                            </ul>
                                        </div>
                                        
                                        
                                        <nav class="further-reading">
                                            
                                            <div class="previous">
                                                <span>&lt;&lt; Prev</span>
                                                <a href="https://www.lican.asia/posts/posts/reading/programmer-accom-base/"
                                                    rel="prev">必知必会！计算机里一些基本又重要的概念</a> </div>
                                            
                                            
                                            <div class="next">
                                                <span>Next >></span>
                                                <a href="https://www.lican.asia/posts/posts/reading/programmer-compile-link/">应用编译，计算机中那些一定要掌握的知识细节</a> 
                                            </div>
                                            
                                        </nav>
                                    </div>
                                    
                                    

                                    
                                    
                                    

                                </div>
                            </article>
                        </div>
                    </div>
                </section>
                <aside class="sidebar sidebar-primary" id="sidebar-primary" role="complementary">
    <h1 class="screen-reader-text">Sidebar</h1>
    

    
    
    <section id="text-2" class="widget widget_text">
        <div class="textwidget">
            
            <div id="profile">
                <div id="profile_picture"><img src="https://www.lican.asia/logo/logo.png"></div>
                <div id="profile_intro">
                    <p><span class="name">Lican</span></p>
                    <p class="intro">全栈开发者，爱好造轮子。</p>
                </div>
            </div>
            
            <p>
                <script type="text/javascript">
                    (function ($) {
                        $(document).ready(function () {
                            var menuPrimaryContainer = $('#menu-primary-container');
                            var profile = $('#text-2');
                            $('#toggle-navigation').click(function () {
                                if (menuPrimaryContainer.hasClass('open')) {
                                    profile.removeClass('open');
                                } else {
                                    profile.addClass('open');
                                }
                            });
                        });
                    })(jQuery);
                </script>
            </p>
        </div>
    </section>
    
    
    
    
    
    <section id="text-5" class="widget widget_text">
        <h2 class="widget-title">开源项目</h2>
        <div class="textwidget">
            <div id="projects" style="line-height: 22px;">
                
                <a href="https://github.com/idoubi/gonews"
                    target="_blank">gonews</a>: &nbsp;Daily news for golang<br>
                
                <a href="https://github.com/idoubi/sql2struct"
                    target="_blank">sql2struct</a>: &nbsp;Generate go struct according to SQL<br>
                
                <a href="https://github.com/idoubi/goz"
                    target="_blank">goz</a>: &nbsp;Request library used in golang<br>
                
        </div>
    </section>
    
    

    
    
    
    
    <section id="qrcode" class="widget widget_media_image">
        <h2 class="widget-title">微信公众号</h2>
        <img width="258" height="258"
            src="https://www.lican.asia/wechat/lican.png"
            class="image wp-image-5514  attachment-full size-full" alt=""
            style="max-width: 100%; height: auto;"
            sizes="(max-width: 258px) 100vw, 258px">
    </section>
    
    

    
    
    

    
    
    

    
    
    
    
</aside>
            </div>
        </div>

        <footer id="site-footer" class="site-footer" role="contentinfo">
    <div class="max-width">
    </div>
    <div class="footer">
        <div id="footercontent">
            © lican.asia All rights reserved<br/>
            Built with Hugo Theme <a href="https://github.com/idoubi/hugo-theme-period" target="_blank">Period</a>
        </div>
    </div>
</footer>

<script>
    var _hmt = _hmt || [];
    (function() {
      var hm = document.createElement("script");
      hm.src = "https://hm.baidu.com/hm.js?e8351b6d4626d5881d439ea1f6184baa";
      var s = document.getElementsByTagName("script")[0]; 
      s.parentNode.insertBefore(hm, s);
    })();
</script>
    
    
    </div>
    
</body>

</html>